$(function () {
    initcate();
    // 1. 初始化图片裁剪器
    var $image = $('#image')

    // 2. 裁剪选项
    var options = {
        aspectRatio: 400 / 280,
        preview: '.img-preview'
    }

    // 3. 初始化裁剪区域
    $image.cropper(options)


    $('#coverFile').change(function () {
        if (this.files.length === 0) return layer.msg('请选择图片')

        var imageURL = URL.createObjectURL(this.files[0]);

        $image
            .cropper('destroy')      // 销毁旧的裁剪区域
            .attr('src', imageURL)  // 重新设置图片路径
            .cropper(options)        // 重新初始化裁剪区域
    });

    var state = '已发布';
    $('#btn2').click(function () {
        state = '草稿'
    });

    $('#form-pub').submit(function (e) {
        e.preventDefault();
        var fd = new FormData(this);
        // fd.forEach(function (value, key) {
        //     console.log(value, key)
        // })
        fd.append('state', state)
        $image
            .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
                width: 400,
                height: 280
            })
            .toBlob(function (blob) {       // 将 Canvas 画布上的内容，转化为文件对象
                // 得到文件对象后，进行后续的操作
                fd.append('cover_img', blob)
                $.ajax({
                    type: 'post',
                    url: '/my/artivle/add',
                    data: fd,
                    processData: false,
                    contentType: false,
                    success: function (res) {
                        if (res.status !== 0) {
                            return layer.msg('发布文章失败！')
                        }
                        layer.msg('发布文章成功！')
                        // 发布文章成功后，跳转到文章列表页面
                        location.href = '/article/art_list.html'
                    }
                })
                fd.forEach(function (value, key) {
                    console.log(value, key)
                })
            })
    })
})
function initcate() {
    $.ajax({
        type: 'get',
        url: '/my/article/cates',
        success: function (res) {
            console.log(res)
            var str = template("cate-tpl", res)
            $('[ name="cate_id"]').html(str);
            layui.form.render('select');

            initEditor()
        }
    })
}

$('#btnFile').click(function () {
    $('#coverFile').click();
})


